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Consultas relacionales 


El punto más fuerte de las bases de datos relacionales es bueno, justamente 
relacionarse 


Utilizando SOL podemos realizar operaciones de junta, combinando 
columnas de una o más tablas 


Las operaciones de junta del estandar SQL son llamados JOINS, y existen 5 
tipos básicos 


Tipos de JOINS 
+ INNER (incluye NATURAL JOIN) 
+ LEFT OUTER 
* RIGHT OUTER 
+ FULL OUTER 
+ CROSS 


SELECT *x 

FROM tablal A 

INNER JOIN tabla2 B 
ON A.clave = B.clave 


Figure 1: INNER JOIN 


NATURAL JOIN 


Consideramos que tenemos un atributo en común 


SELECT x 
FROM tabla1l A 
NATURAL JOIN tabla2 B 


Figure 2: NATURAL JOIN 


SELECT x SELECT *x 


FROM tabla1l A FROM tablal A 
LEFT JOIN tabla2 B LEFT JOIN tabla2 B 
ON A.clave = B.clave ON A.clave = B.clave 


WHERE B.clave IS NULL 


Figure 3: LEFT OUTER JOIN 


RIGHT OUTER JOIN 


SELECT x SELECT x 

FROM tablal A FROM tablal A 

RIGHT JOIN tabla2 B RIGHT JOIN tabla2 B 
ON A.clave = B.clave ON A.clave = B.clave 


WHERE A.clave IS NULL 


Figure 4: RIGHT OUTER JOIN 


CO) 


a SELECT x 

FROM tablal A 
FROM tabla1l A FULL JOIN tabla2 B 
FULL JOIN tabla2 B ON Azeláve == B.clave 
ON A.clave = B.clave WHERE A.clave IS NULL 


OR B.clave IS NULL 


Figure 5: FULL OUTER JOIN 


SELECT x SELECT x 
FROM tablal A FROM tablal A, 
CROSS JOIN tabla2 B tabla2 B 


Figure 6: CROSS JOIN 


Estudiantes y cursos 


Vamos a mostrar un ejemplo trabajando con una base de datos de 
estudiantes y cursos 


id 
id_curso INTEGER : nombre 
nombre TEXT mail 
fecha TEXT password 

xp 

id_curso 


Figure 7: Tablas estudiantes y cursos 


INTEGER 


TEXT 


TEXT 


TEXT 


TEXT 


INTEGER 


INTEGER 
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SELECT * 
FROM estudiantes 
/*INNER */JOIN cursos 
ON cursos.id_curso = estudiantes.id_ curso 


NATURAL JOIN 


SELECT x*x 
FROM estudiantes 
CROSS JOIN cursos -- 1d_curso 


LEFT OUTER JOIN 


SELECT * 
FROM estudiantes 
LEFT /*0UTER */ JOIN cursos 
ON cursos.id_curso = estudiantes.id_ curso 


RIGHT OUTER JOIN 


SELECT * 
FROM estudiantes 
RIGHT JOIN cursos 
ON cursos.id_curso = estudiantes.id_ curso 


RIGHT OUTER JOIN EN SQLITE 


SELECT *x 
FROM cursos 
LEFT JOIN estudiantes 
ON estudiantes.id_curso = cursos.id_curso 
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FULL OUTER JOIN 


SELECT * 
FROM estudiantes 
FULL JOIN cursos 
ON cursos.id_curso = estudiantes.id_ curso 
-- ORDER BY id_curso 


FULL OUTER JOIN EN SQLITE 


SELECT * 
FROM estudiantes 
LEFT JOIN cursos 
ON cursos.id_curso = estudiantes.id_ curso 
UNION --ALL 
SELECT *x 
FROM cursos 
LEFT JOIN estudiantes 
ON estudiantes.id_curso = cursos.id_curso 
WHERE estudiantes.id_curso IS NULL 


CROSS JOIN 


SELECT * 

FROM estudiantes 
CROSS JOIN cursos 
EMT O O) 
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Se puede simplificar la clausula ON del JOIN en caso de que ambas columnas 
se llamen igual 


SELECT *x 
FROM estudiantes 
JOIN cursos 


-=- ON cursos.id_curso = estudiantes.id_curso 
USING(id_curso) 
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Multiples tablas en FROM 


SELECT * 
FROM estudiantes, cursos 
WHERE cursos.id_curso = estudiantes.id_curso 
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Auto JOIN o self JOIN 


SELECT * 
FROM cursos 
JOIN cursos curso_padre 
ON curso _padre.id_curso_hijo = cursos.curso_hijo 
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Relación muchos a muchos 


Creamos una tabla intermedia para manejar la relación que llamaremos 
estudiantes_cursos. La misma estara relacionada de 1 a muchos tanto con 
estudiantes como con cursos 


SELECT estudiantes.*, cursos.*, estudiantes_cursos.fecha 
FROM estudiantes 
JOIN estudiantes_cursos 

ON estudiantes_cursos.id estudiante = estudiantes.id 
JOIN cursos 

ON cursos.id_curso = estudiantes_cursos.id_ curso 


23 


¡Muchas Gracias! 


continuará... 


